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In this paper we give a criterion by which one can conclude that every reduction of a basic term 
to normal form has the same length. As a consequence, the number of steps to reach the normal 
form is independent of the chosen strategy. In particular this holds for TRSs computing addition and 
multiphcation of natural numbers, both in unary and binary notation. 

1 Introduction 

For many term rewriting systems (TRSs) the number of rewrite steps to reach a normal form strongly 
depends on the chosen strategy. For instance, in using the standard if-then-else-rules 

if(true,A:, j) — 7- .X if(false,x, j) — )• 3^ 

it is a good strategy to first rewrite the leftmost (boolean) argument of the symbol if until this argument 
is rewritten to false or true and then apply the corresponding rewrite rule for if. In this way redundant 
reductions in the third argument are avoided in case the condition rewrites to true, and redundant reduc- 
tions in the second argument are avoided in case the condition rewrites to false. More general, choosing 
a good reduction strategy is essential for doing efficient computation by rewriting. Roughly speaking, 
for erasing rules, that is, some variable in the left-hand side does not appear in the right-hand side, it 
seems a good strategy to postpone rewriting this possibly erasing argument, as is the case in the above 
if-then-else example. Conversely, in case of duplicating rules, that is, a variable occurs more often in 
the right-hand side than in the left-hand side, it seems a good strategy to first rewrite the corresponding 
argument before duplicating it. 

Surprisingly however, there are practical examples of TRSs including both such erasing and dupli- 
cating rules, where the strategy has no influence at all on the number steps required to reach a normal 
form. In this paper we investigate criteria for this phenomenon. As an example, using the results of this 
paper, we will show that for multiplying two natural numbers by the standard TRS 

plus(0,x) — ^ X mult(0,x) — ^ 

plus(s(x),j) — )- s(plus(x,j)) mult(s(x),3') — )- plus(mult(x,y), 

the number of steps to reach the resulting normal form is independent of the chosen strategy. Note that 
the third rule of this TRS is erasing, and the last rule is duplicating. 

In this TRS ground terms reduce to ground normal forms of the shape s" (0) for any natural number n, 
representing the corresponding number n in unary notation. For large numbers n this is a quite inefficient 
representation. Much more efficient is the binary representation. In this paper we also give a TRS for 
doing addition and multiplication in binary representation. Here for every addition or multiplication of 
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two positive integer numbers we show by the main theorem of this paper that every reduction to normal 
form has the same number of steps. Moreover, this number has the same complexity as the standard 
binary algorithms: linear for addition and quadratic for multiplication. 

Throughout the paper we assume familiarity with standard notions in rewriting like orthogonality 
and normal forms as they are introduced in e.g. [4|. For instance, a reduction is a sequence of rewrite 
steps, and a reduct of a term f is a term u for which there is a reduction from t to u. 

In Section [2] we investigate the diamond property and present our main result in Theorem |3} a cri- 
terion by which for every basic term all reductions to normal form have the same length. Here a term 
is called basic if only its root is a defined symbol. We apply this to unary arithmetic. In Section [3] it is 
shown how our theorem applies to binary arithmetic. We conclude in Section]?] 

2 The diamond property and the main result 

We say that a binary relation — satisfies the diamond property, if for every three elements s,t,u satisfying 
5 — )• f and 5 — )• M and t ^u, there exists an element w such that f — )• w and u^w. 

This notion is slightly different from other variants of the diamond property, for instance introduced 
in HJ where it is typically used for reflexive relations. However, as we are interested in the exact number 
of steps to reach a normal form, our present version is the most natural in our context. In earlier texts it 
was sometimes called WCR^. It is an instance of the balanced weak Church-Rosser property from lH. 
The following lemma is a direct consequence of both Lemma 1 from i5J and the random descent lemma 
from ||3] ; to make the paper self-contained here we give a proof too. 

Lemma 1 Let be a relation satisfying the diamond property. Then every element has at most one 
normal form, and for every element having a normal form it holds that every reduction of this element to 
its normal form has the same number of steps. 

Proof. This follows from the following claim: 

Let t be an element having normal form n. Then every reduct of t has normal form n, and 
every — s-reduction from t ton has the same number of steps. 

We prove this by induction on k, where k is the number of steps of a reduction from t to n. 
If ^ = then f is a normal form, and the lemma holds. 

If A; > assume t ^ti -^^^^ n and t -^p u; we will prove that u -^'^ n for q satisfying p + q = k. Then 
indeed the lemma follows by applying this claim both for u being the arbitrary reduct of t and for u = n. 

For p = the claim trivially holds, so assume p > and t ^ tj — t-''^' u. In case ti = tj we apply the 
induction hypothesis to ti = t2 and we are done. In the remaining case by the diamond property there 
exists V such that fi — )• v and t2 — )• v. By applying the induction hypothesis to ti we conclude v — j.*^^^ 
yielding ?2 — s-'^^' n. Next we apply the induction hypothesis to ^2^ so u — )■* n and every reduction from ?2 
to n has length k—\,p + q = k, concluding the proof. □ 

An orthogonal TRS is said to be variable preservin^if for every rule £ ^ r every variable occurring 
in £ occurs exactly once in r. For instance, the TRS consisting of the two rules for plus as given in the 
introduction, is variable preserving. 

Lemma 2 Let R be a variable preserving orthogonal TRS. Then the relation -^r on the set of all terms 
satisfies the diamond property. 

' Some texts have a weaker notion of variable presendng, but our version is more suitable for investigating reduction lengths. 



Hans Zantema 



71 



Proof. Similar to the proof of the well-known critical pair lemma (see e.g., (4), Lemma 2.7.15) we do a 
case analysis on the redex patterns. If a term t has one-step reductions to two distinct terms u and v, then 
by orthogonality one of the following cases holds: 

1. (the redexes are parallel) t = C[£f ,^|] and u = C[rf ,£l] and v = C[£^ ,rl], for a two-hole context 
C, substitutions, a, T and rules £{ — )• r,- in /? for / = 1 , 2, 

2. (one redex is above the other) t = C[£'^] and u = C[r^] and v = C[£^], for a rule i ^ r in R and a 
context C, and substitutions a, r such that — )•« for some variable x occurring in £, and = y'^ 
for all variables y distinct from x, 

or the same in which u and v are swapped. For both cases we have to find w such that m — w and 
V — w. For case (1) this holds by choosing w = C[rJ^, r2]. 

For case (2) write £ = D\x\. Since /? is left-linear, x does not occur in D. Since /? is variable preserving, 
we can write r = £ [jc] for a context E not containing x. Now we obtain 

u = C[r^] = C[£^[x^]] C[£^[x^]] and v = C[£"] ^« C[rT = C[£"[x"]]. 

Since x does not occur in E we have f""^ = 5^, by which w = C[£"^[x^]] = C[£'^[x^]] satisfies the require- 
ments for w. □ 

As a direct consequence of Lemmas [T] and |2] we conclude that for all terms with respect to the two 
plus rules from the introduction the number of steps to reach the normal form is independent of the 
strategy. This does not hold any more for the full system also containing the rules for mult. For instance, 
the term mult(0, plus(0,0)) admits the following two reductions to normal form having lengths one and 
two, respectively: 

mult(0,plus(0,0)) 0, mult(0,plus(0,0)) -^r mult(0,0) -^r 0. 

However, here the starting term mult(0, plus(0,0)) is not basic: it contains more than one defined 
symbol. A symbol is called a defined symbol if it occurs as the root of the left-hand side of a rule. Similar 
as in texts on run-time complexity like [2 J we define: 

A term is defined to be basic if the root is a defined symbol, and it is the only defined symbol 
occurring in the term. 

We will prove that for basic terms like terms of the shape mult(s™(0),s"(0)) every reduction to its 
normal form s'""(0) has the same length. 

Theorem 3 Let R be an orthogonal TRS over £, and £' C £, such that every rule £ — >• r ofR is of one of 
the following shapes: 

• £^ r is variable preserving, and neither £ nor r contain symbols from Yl, 

• the root of£ is in and for every symbol in rfrom Z' the arguments of this symbol do not contain 
defined symbols. 

Then any two reductions of a basic term to normal form have the same length. 

Proof. First we prove the following claim. 

Claim: If f is a basic term and t — s-^ u, then for every symbol from E' in u the arguments of 
this symbol do not contain defined symbols. 



72 



Strategy Independent Reduction Lengths and Binary Arithmetic 



We prove this claim by induction on the number of steps in the reduction t — u. If this number is 0, 
then u = t and the claim follows from the definition of basic term. 

If this number is > 0, then t — u' — u, where by induction hypothesis we assume that the claim 
holds for u'. For every subterm of u having its root in we have to prove that this subterm does not 
contain other defined symbols. For every such subterm that also occurs in u' this holds by the induction 
hypothesis. The only way such a subterm may occur in u but not in u' is that it is created by replacing 
by for some substitution a and a rule £ — )• r of the second type: the root of i is in £' and arguments 
of symbols from £' in r do not contain defined symbols. Since i'^ is a subterm of u' and the property 
holds for u' by induction hypothesis, for all variables xini the term x^ does not contain defined symbols. 
Hence every subterm of having its root in Z' does not contain other defined symbols, concluding the 
proof of the claim. 

Next we show that the relation — )>r restricted to terms u obtained by t — u for some basic term t, 
satisfies the diamond property. To prove this, let such a term u both rewrite to v and to w, v / w. In case 
the redexes are parallel, then the diamond property is easily concluded as in the proof of Lemma [2j case 
I. 

In the remaining case one redex is above the other. Due to the claim and the shape of the rules, one 
of the following cases holds: 

• The roots of both redexes are not in Then both reduction steps are with respect to variable 
preserving rules, and the diamond property follows from Lemma[2] 

• The root of the innermost (of the two) redexes is in but the root of the outermost redex is 
not. Then the reduction with respect to the outermost redex is variable preserving, by which the 
diamond property can be concluded. 

In all cases the diamond property of — s-r restricted reducts m of a basic term t can be concluded. Now the 
theorem follows from Lemma [T] □ 

Indeed now by Theorem|3]we can conclude that with respect to the TRS with plus and mult as given 
in the introduction for every basic term of the shape mult(s'"(0),s"(0)) every reduction to its normal 
form s™"(0) has the same length: let Z' consist of the single symbol mult. Then the two rules for plus 
satisfy the condition for rules of the first type, and the two rules for mult satisfy the condition for rules 
of the second type, by which the claim follows from Theorem[3] 

As another example consider the Fibonacci function f i b defined by the rules 

plus(0,x) X fib(O) 

plus(s(x),j) — ;> s(plus(;ii;,j)) fib(s(0)) — ;> s(0) 

fib(s(s(.x:))) ^ plus(fib(jc),fib(s(x))). 

Choosing £' to consist only of the symbol fib, all requirements of Theorem [3] hold, so we conclude that 
for every k every reduction of fib(s'^(0)) to normal form has the same length. 

For another standard recursive function, the factorial, it does not hold that distinct reductions of basic 
terms to normal forms have the same length. By extending our basic rules for plus and mult from the 
introduction by the rules for factorial 

fact(O) ^ s(0) 
fact(s(x)) — mult(s(x),fact(x)) 

the basic term fact(s(0)) admits reductions of lengths both 5 and 6 to its normal form s(0)), caused by 
the fact that after 



fact(s(0)) mult(s(0),fact(0)) plus(mult(0,fact(0)),fact(0)) 
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the subterm mult(0,fact(0)) can be rewritten to in one step, but also in two steps via mult(0,s(0)). 
Indeed Theorem|3]does not apply here since mult should be in Z' as before, and also fact G £' since mult 
occurs in the right-hand side of a rule for fact. But then this rules violates the conditions: fact(x) occurs 
as an argument of the symbol mult in this right-hand side. 

The converse of Theorem[3]does not hold, not even for terminating orthogonal exhaustive constructor 
systems. Here exhaustive (in case of termination equivalent to sufficiently complete) means that for every 
defined symbol applied to ground constructor forms at least one rule is applicable, by which all ground 
normal forms are constructor terms. 

For instance, consider the TRS consisting of the three rules 

f(0)^0, f(sW)^s(0), gW^f(f(x))). 

As f and g are defined symbols, the only basic terms are of the shape f(s"(x)), f(s"(0)), g(s"(x)) or 
g(s"(0)), for n>0. All of these terms only admit one single reduction to normal form of at most three 
steps, as is easily checked by applying the rules. So any two reductions of a basic term to normal form 
have the same length. However, this can not be concluded from Theorem [3] since this TRS does not 
satisfy its conditions: the rule f (s(x)) — s(0) is not variable preserving, so for satisfying the conditions it 
should hold f G But then the third rule does not satisfy the conditions as there is a nested occurrence 
of f in the right-hand side. 



3 Binary arithmetic 

For more efficient computation of numbers it is natural to exploit binary notation, in which the size of the 
representation is logarithmic rather than linear in the value of the number, and in which basic arithmetic 
can be executed by rewriting in a complexity that is polynomial in the size of this representation, so 
logarithmic in the values of the numbers. Although the general idea is folklore, there is not a single 
fixed standard. Here we present a straightforward way to proceed for implementing binary arithmetic 
by rewriting. It is related to the non-orthogonal system from |i6j| for ?i-ary arithmetic for arbitrary n for 
all integers. By restricting to n = 2 and positive integers, here we succeed in presenting an orthogonal 
system. 

In standard binary notation positive integers can be seen to be uniquely composed from a constant 1 
representing value 1, and two unary operators .0 and .1, where .0 means putting a behind the number, 
by which its value is duplicated, and . 1 means putting a 1 behind the number, by which its value x is 
replaced by 2x+ 1. 

Every positive integer has a unique representation as a ground term over these three symbols 1, .0 
and .1, corresponding to the usual binary notation in which a postfix notation for .0 and .1 is used. For 
instance, the number 29 is 1 1 101 in binary notation, and is written as 1.1.1.0.1 as a postfix ground term. 
Since in term rewriting it is more standard to use prefix notation rather than postfix notation, here we 
choose to switch to prefix notation. So instead for 29 we write .1(.0(.1(.1(1)))). Introducing a constant 
would violate unicity, that is why we restrict to positive integers. 

In order to express addition and multiplication in this notation the successor succ is needed as an 
additional operator, having rewrite rules 

succ(l) ^ .0(1) 
succ(.0(x)) .l{x) 
succ(.l(x)) — > .0(succ(x)) 
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Now we can express addition: 



plus(l,jc) — succ(;t;) 
plus(.0(x),l) .l(x) 
plus(.l(x),l) — )- .0(succ(x)) 



plus(.0(x),.0(y)) 
plus(.0(x),.l(3;)) 
plus(.l(x),.0(3^)) 
plus(.l(x),.l(3;)) 



0(plus(x,j)) 
l(plus(x,j)) 
l(plus(x,3;)) 



0(succ(plus(x,j))) 



Indeed now for every ground term composed from l,.0,.l,succ,plus containing at least one symbol 
succ or plus a rule is applicable. So the ground normal forms are the ground terms composed from 
1, .0, .1, exactly being the binary representations of positive integers. Since the TRS is easily proved to 
be terminating, e.g., by recursive path order, every ground term will reduce to such a ground normal 
form, being the binary representations of a positive integer. As by every rule the numeric value of the 
term is preserved, this TRS serves for computing the binary value of any ground term considered so far. 

Surprisingly, it is very simple to extend this system to multiplication, by using the fresh symbol mult 
for multiphcation and introducing the following rules 



The above observations are also easily checked for the extended TRS consisting of all rules presented 
so far: all rules preserve values, and for every ground term composed from 1, .0, .1, succ, plus, mult 
containing at least one symbol succ or plus or mult a rule is applicable. So the ground normal forms are 
the ground terms composed from 1, .0, .1, exactly being the binary representations of positive integers. 
Also the extended TRS is easily proved to be terminating, e.g., by recursive path order, so every ground 
term will reduce to such a ground normal form, being the binary representations of a positive integer. So 
the extended TRS also serves for executing multiplication. 

Choosing Z' to consist of the single symbol mult it is easily checked that all conditions of Theoremjs] 
are satisfied. So by Theorem |3] we conclude that for using this TRS for computing the addition or multi- 
plication of two binary numbers, every reduction to normal form has the same length. This observation is 
of great value: a lot of effort is done in choosing the right rewriting strategy; this observation shows that 
when binary arithmetic is only used for addition and multiplication (which is often the case), strategy 
optimization is useless since all reductions to normal form are of the same complexity as they all have 
the same length. 

In 17] it is proved that for addition this reduction length is linear in the size of the arguments, and for 
multiplication it is quadratic in the size of the arguments, so having the same complexity as the standard 
algorithms for binary addition and multiplication. The TRSs as presented in Q have been the basis of 
the implementation of integer number computation in the mCRL2 tool set HI. 

In our rules for multiplication the recursion is only in the first argument. For computing 2" * m for 
any number m this is very efficient: the result is obtained after 0{n) steps, independent of the value of m. 
However, for computing m*2" this is not efficient at all: first m will be decomposed and many copies of 
2" wiU be created, finally giving the same result as the computation of 2" * m. To bring more symmetry 
and to make the computations of m * 2" and 2" * m both be hnear in n, we can choose the rules for mult 




Hans Zantema 



75 



to be 

mult(l,l) ^ 1 

mult(.0(x),l) .0(x)) 

mult(.l(x),l) ^ .l(x)) 

mult(l,.0(x)) ^ .0(x)) 

mult(l,.l(x)) ^ .l(x)) 

mult(.0(x),.0(3;)) .0(.0(mult(x,3;))) 

mult(.0(x),.l(3;)) ^ .0(mult(x, .1(3;))) 

mult(.lW,.0(y)) ^ .0(mult(.l(x),y)) 

mult(.l(x),.l(3;)) ^ plus(.0(mult(x,.l(3;))),.l(3;)). 

In this way duplication of arguments and introducing plus is only done if both arguments of mult are of 
the shape .!(•••). Although slightly more complicated, it is easy to check that the full system consisting 
of the rules for succ, plus and these new rules for mult 

• only rewrites terms to terms having the same value, 

• is terminating (again by recursive path order), 

• satisfies the conditions of Theorem [5] for Z' = {mult}, and 

• computes both m * 2" and 2" * m in 0{n) rewrite steps, independent of the value of m. 

Hence by Theorem [3} we conclude that for this improved system for binary arithmetic for every basic 
term any two reductions to normal form have the same length. 



4 Conclusion 

Basic terms are typical terms to be rewritten: a defined symbol on top and constructor terms as arguments. 
We gave a criterion for orthogonal TRSs by which all reductions of a basic term to normal form have 
the same length, showing that the reduction length is independent of the chosen strategy. This applies to 
both addition and multiplication, both in unary and binary notation. This result is surprising: it shows 
that for these basic computations as they often occur in practice, all possible reduction strategies have 
the same complexity. 

In unary notation the Fibonacci function still satisfies our criteria. However, for more complicated 
user defined functions experiments based on a simple implementation show that reduction lengths of 
basic terms are typically not strategy independent any more. 

Acknowledgment. We want to thank Evans Kaijage for fruitful discussions on this topic and for 
doing some experiments. 
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